## WHAT IS CLAIMED IS:

| 1  | 1. A method comprising:                                                         |
|----|---------------------------------------------------------------------------------|
| 2  | a memory circuit receiving a data frame to be subsequently transmitted to a     |
| 3  | destination device via a first or second switching fabric, wherein the          |
| 4  | data frame comprises header and data fields, and wherein the first              |
| 5  | switching fabric comprises data ports through which data frames enter           |
| 6  | or exit the first switching fabric, wherein the second switching fabric         |
| 7  | comprises data ports through which data frames enter or exit the                |
| 8  | second switching fabric;                                                        |
| 9  | selecting a first multi-bit value [MASK] from a plurality of first multi-bit    |
| 10 | values according to the data contained in the one of the header fields,         |
| 11 | wherein the selected first multi-bit value comprises concatenated first         |
| 12 | and second multi-bit portions, wherein the bits of the first multi-bit          |
| 13 | portion correspond, respectively, to the data ports of the first and            |
| 14 | second switching fabrics, and wherein the bits of the second multi-bit          |
| 15 | portion correspond, respectively, to the data ports of the first and            |
| 16 | second switching fabrics;                                                       |
| 17 | selecting a second multi-bit value [FPOE] from a plurality of second multi-bit  |
| 18 | values according to the data contained in the one of the header fields,         |
| 19 | wherein the bits of the first multi-bit value correspond, respectively, to      |
| 20 | the data ports of the first and second switching fabrics;                       |
| 21 | concatenating the second multi-bit value with itself to produce a concatenated  |
| 22 | second multi-bit value;                                                         |
| 23 | bit wise logically ANDing the selected first multi-bit value with the           |
| 24 | concatenated second multi-bit value to produce a third multi-bit value,         |
| 25 | wherein the third multi-bit comprises concatenated first and second             |
| 26 | portions;                                                                       |
| 27 | selecting one of the first and second portions of the third multi-bit value;    |
| 28 | adding the selected one of the first and second portions of the third multi-bit |
| 29 | value to another header field of the received data frame;                       |
| 30 | transmitting the received data frame from the memory circuit to one of the      |
| 31 | first and second switching fabrics;                                             |

1

2

3

4

1

2

3 4

the data frame exiting the one of the first and second switching fabrics through 32 one or more data ports thereof in accordance with the values of the bits 33 of the selected one of the first and second portions of the third multi-bit 34 35 value.

- The method of claim 1 wherein the memory circuit is coupled to the 1 2. first and second switching fabrics via first and second data ports, respectively, 2 wherein the first data port is one of the first switching fabric data ports and the second 3 data port is one of the second switching fabric data ports. 4
- The method of claim 2 wherein the data frame is transmitted to the first 1 3. switching fabric via the first data port or the second switching fabric via the second 2 data port.
  - The method of claim 1 wherein the destination device is coupled to the 4. first and second switching fabrics via third and fourth data ports, respectively, wherein the third data port is one of the first switching fabric data ports and the fourth data port is one of the second switching fabric data ports.
  - 5. The method of claim 4 wherein the data frame is transmitted from the first switching fabric to the destination device via the third data port or the data frame is transmitted from the second switching fabric to the destination device via the fourth data port.
- 1 6. The method of claim 1 wherein each bit of the second multi-bit value is set to logical 1 or logical 0, wherein each bit set to logical 1 corresponds, 2
- 3 respectively, to one of the data ports of the first and second switching fabrics through
- which the data frame may exit to reach the destination device. 4

2 3

4

1

2

3

4

5

6

7

9

10 11

12 13

14 15

16

17

18 19

20

21

| 1 | 7. The method of claim 4 wherein each bit of the first and second                           |
|---|---------------------------------------------------------------------------------------------|
| 2 | portions of the first multi-bit value is set to logical 1 or logical 0, wherein each of the |
| 3 | first and second portions of the first multi-bit value comprises a first bit that           |
| 4 | corresponds to the fourth data port, and wherein only one of the two first bits is set to   |
| 5 | logical 1.                                                                                  |

- 8. The method of claim 1 wherein only one bit of the selected one of the first and second portions of the third multi-bit value is set to logical 1, and wherein the one bit corresponds to a particular data port of the first and second switching fabric ports through which the data frame must exit to reach the destination device.
  - 9. An apparatus comprising:
  - a memory circuit configured to receive a data frame to be subsequently transmitted to a destination device via a first or second switching fabric, wherein the data frame comprises header and data fields, wherein the first switching fabric comprises data ports through which data frames enter or exit the first switching fabric, and wherein the second switching fabric comprises data ports through which data frames enter or exit the second switching fabric;
  - a first circuit coupled to the memory circuit, wherein the first circuit is configured to receive data from one of the header fields, and wherein the first circuit is configured to produce a first multi-bit value in response to receiving the data;
  - a second circuit coupled to the memory circuit, wherein the second circuit is configured to receive the data, and wherein the second circuit is configured to produce a second multi-bit value in response to receiving the data:
  - a third circuit coupled to the first and second circuits, wherein the third circuit is configured produce a third multi-bit value in response to receiving the first and second multi-bit values from the first and second circuits, respectively, wherein the third circuit is configured to add the third multi-bit to another header field of the data frame;

648762 v2

1

2

3

4

1

2

3

4 5

1

2

3

4

1

2

3

4

5

6 7

wherein the memory circuit is configured to transmit the data frame to the first or second switching fabric after the third multi-bit value is added to the header field;
wherein the third multi-bit value identifies one of the data ports of the first or second switching fabrics through which the data frame must exit the

- switching fabric to reach the destination device.

  10. The apparatus of claim 9 wherein the memory circuit is coupled to the
- first and second switching fabrics via first and second data ports, respectively, wherein the first data port is one of the first switching fabric data ports and the second data port is one of the second switching fabric data ports.
  - 11. The apparatus of claim 9 further comprising the first and second switching fabrics and the destination device, wherein the destination device is coupled to the first and second switching fabrics via third and fourth data ports, respectively, wherein the third data port is one of the first switching fabric data ports and the fourth data port is one of the second switching fabric data ports.
  - 12. The apparatus of claim 9 wherein each bit of the second multi-bit value is set to logical 1 or logical 0, wherein each bit set to logical 1 corresponds, respectively, to one of data ports of the first and second switching fabrics through which the data frame may exit to reach the destination device.
  - 13. The apparatus of claim 9 wherein the first multi-bit value comprises concatenated first and second multi-bit portions, wherein the bits of the first multi-bit portion correspond, respectively, to the data ports of the first and second switching fabrics, wherein the bits of the second multi-bit portion correspond, respectively, to the data ports of the first and second switching fabrics, wherein each of the first and second portions of the first multi-bit value comprises a first bit that corresponds to the fourth data port, and wherein only one of the two first bits is set to logical 1.

|   | 14. TI             | ne apparatus of claim 9 wherein the third circuit comprises a        |
|---|--------------------|----------------------------------------------------------------------|
| 2 | concatenation cir  | cuit and an ANDing circuit, wherein the concatenation circuit is     |
| 3 | configured to cor  | ncatenate the second multi-bit value with itself to produce a        |
| ļ | concatenated sec   | ond multi-bit value, and wherein the ANDing circuit is configured to |
| 5 | bit wise logically | AND the first multi-bit value with the concatenated second multi-bit |
| 5 | value.             |                                                                      |

15. The apparatus of claim 9 wherein only one bit of the third multi-bit value that is set to logical 1, and wherein the one bit corresponds to one data port of the first and second switching fabrics through which the data frame must exit to reach the destination device.

## 16. An apparatus comprising:

a buffer configured to receive a data frame to be transmitted to a destination device via a first or second switching fabric, wherein the first switching fabric comprises data ports through which data frames enter or exit the first switching fabric, and wherein the second switching fabric comprises data ports through which data frames enter or exit the second switching fabric;

a routing data generation circuit coupled to the buffer, wherein the routing data generation circuit is configured to generate and add routing data to the data frame received by the buffer, wherein the routing data identifies one of the data ports of the first or second switching fabric through which the data frame will exit to reach the destination device; wherein the buffer is configured to transmit the received data frame to the switching system after the routing data generation circuit adds the

routing data to the data frame.

2

3

5

6

7

8

9

10

11

12

13 14

1

2

3

| l | 17. The apparatus of claim 16 the buffer is coupled to the first and second             |
|---|-----------------------------------------------------------------------------------------|
| 2 | switching fabrics via first and second data ports, respectively, wherein the first data |
| 3 | port is one of the first switching fabric data ports and the second data port is one of |
| 1 | the second switching fabric data ports.                                                 |

## 18. An apparatus comprising:

- a memory circuit configured to receive a data frame to be transmitted to a destination device via a first or second switching fabric, wherein the first switching fabric comprises data ports through which data frames enter or exit the first switching fabric, and wherein the second switching fabric comprises data ports through which data frames enter or exit the second switching fabric;
- means coupled to the memory circuit, to generate and add routing data to the data frame received by the memory circuit, wherein the routing data identifies one of the data ports of the first or second switching fabric through which the data frame will exit to reach the destination device; wherein the memory circuit is configured to transmit the received data frame
- to the switching system after the means adds the routing data to the data frame.
- 19. The apparatus of claim 18 wherein the memory circuit is coupled to the first and second switching fabrics via first and second data ports, respectively, wherein the first data port is one of the first switching fabric data ports and the second
- data port is one of the second switching fabric data ports.

| i  | 20.                                                                        | A method comprising:                                                       |  |  |
|----|----------------------------------------------------------------------------|----------------------------------------------------------------------------|--|--|
| 2  | a memory circuit receiving a data frame to be transmitted to a destination |                                                                            |  |  |
| 3  |                                                                            | device via first or second switching fabrics, wherein the first switching  |  |  |
| 4  |                                                                            | fabric comprises data ports through which data frames enter or exit the    |  |  |
| 5  |                                                                            | first switching fabric, and wherein the second switching fabric            |  |  |
| 6  |                                                                            | comprises data ports through which data frames enter or exit the           |  |  |
| 7  |                                                                            | second switching fabric;                                                   |  |  |
| 8  | genera                                                                     | ating and adding routing data to the data frame received by the memory     |  |  |
| 9  |                                                                            | circuit, wherein the routing data identifies one of the data ports of the  |  |  |
| 10 |                                                                            | first or second switching fabric through which the data frame will exit    |  |  |
| 11 |                                                                            | to reach the destination device;                                           |  |  |
| 12 | the m                                                                      | emory circuit transmitting the received data frame to the switching        |  |  |
| 13 |                                                                            | system after the routing data has been added to the data frame.            |  |  |
|    |                                                                            |                                                                            |  |  |
| 1  | 21.                                                                        | A computer readable medium storing instructions executable by a            |  |  |
| 2  | computer sys                                                               | tem to implement a method, the method comprising:                          |  |  |
| 3  | a mer                                                                      | nory circuit of the computer system receiving a data frame to be           |  |  |
| 4  |                                                                            | transmitted to a destination device via first or second switching fabrics, |  |  |
| 5  |                                                                            | wherein the first switching fabric comprises data ports through which      |  |  |
| 6  |                                                                            | data frames enter or exit the first switching fabric, and wherein the      |  |  |
| 7  |                                                                            | second switching fabric comprises data ports through which data            |  |  |
| 8  |                                                                            | frames enter or exit the second switching fabric;                          |  |  |
| 9  | gener                                                                      | rating and adding routing data to the data frame received by the memory    |  |  |
| 10 |                                                                            | circuit, wherein the routing data identifies one of the data ports of the  |  |  |
| 11 |                                                                            | first or second switching fabric through which the data frame will exit    |  |  |
| 12 |                                                                            | to reach the destination device;                                           |  |  |
| 13 | the m                                                                      | nemory circuit transmitting the received data frame to the switching       |  |  |
| 14 |                                                                            | system after the routing data has been added to the data frame.            |  |  |